

# 计算机组成与体系结构 数据表示、计算以及指令系统

计算机科学与技术

梅以明理 学以特色

### 数据的表示回顾



- •数据的表示与数据结构
- •传统机器数据表示:
  - 口定点数:原码、反码、补码、移码。
  - □浮点数: 尾数、基数和阶码、IEEE754 标准。
  - 口字符:常用ASCII码。
  - 口汉字:输入码,汉字内码,汉字字模码。
- · 高级数据表示:自定义的数据表示,向量数据表示、堆栈数据表示。
- · 数据校验原理: 奇偶校验码

# 第二部分主要内容



・数据的表示

•数据的计算

・指令系统

### 数据计算学习建议



掌握数值数据在计算机中实现算术运算和逻辑运算的方法,以及 运算部件的基本结构和工作原理。

#### 重点关注:

- 1、串行、并行加法器、溢出判断与检测、移位操作。
- 2、乘法电路基本结构: BOOTH乘法器 (1位)
- 3、除法电路基本结构:加减交替除法器(补码)
- 4、逻辑运算:与、或、非、异或运算
- 5、运算器基本结构

实验一

#### n位加

基本加法器

### 进位产生进位传递函数 用G:表示

$$S_i = A_i \oplus C_{i+1}$$
  
 $C_i = A_i B_i + (A_i \oplus B_i) C_{i+1}$ 

串行加法器:只有一个全加器,数据逐位串行送 入加法器进行运算。如果操作数长*n*位,加法 就要分*n*次进行,每次只能产生一位和。

并行加法器:并行加法器由多个全加器组成,其位数的多少取决于机器的字长,数据的各位同时运算。



# **Carry Generating Function Carry Propagating Function**



### 并行加法器 (Ripple carry adder)



#### n位行波进位加法器



每形成一级进位的延迟时间为2ty。在字长为n位的情况下,若不考虑 $G_i$ 、 $P_i$ 的形成时间,从 $C_0 \rightarrow C_n$ 的最长延迟时间为2nty。

提高并行加法器速度的 关键是尽量加快进位产 生和传递的速度。

#### 超前进位加法器



$$\begin{split} &C_1 = G_1 + P_1 C_0 \\ &C_2 = G_2 + P_2 C_1 = G_2 + P_2 G_1 + P_2 P_1 C_0 \\ &C_3 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 C_0 \\ &C_4 = G_4 + P_4 G_3 + P_4 P_3 G_2 + P_4 P_3 P_2 G_1 + P_4 P_3 P_2 P_1 C_0 \end{split}$$

每个进位都不需要等待低位,直接计算可以得到,这种方法实现的加法器就被称为<mark>超前进位加法器</mark>(Carry\_lookahead Adder, CLA)。

若不考虑 $G_i$ 、 $P_i$ 的形成时间,从 $C_0 \rightarrow C_n$ 的最长延迟时间仅为2ty。但随着加法器位数的增加, $C_i$ 的逻辑表达式会变得越来越长,实现十分复杂,<mark>如何解决?</code> 分组控制规模</mark>

## (1)单级先行进位方式



这种进位方式又称为<mark>组内并行、组间串行</mark>方式。以16位加法器为例,可分为四组,每组四位。第1小组组内的进位逻辑函数 $C_1$ 、 $C_2$ 、 $C_3$ 、 $C_4$ 的表达式与前述相同, $C_1 \sim C_4$ 信号是同时产生的,从 $C_0$ 出现到产生 $C_1 \sim C_4$ 的延迟时间是2ty。





### (2)多级先行进位方式



又称组内并行、组间并行进位方式。

字长为16位的两级先行进位加法器,第一小组的最高位进位 $C_4$ :

$$C_4 = G_4 + P_4G_3 + P_4P_3G_2 + P_4P_3P_2G_1 + P_4P_3P_2P_1C_0$$

$$=G_1^*+P_1^*C_0$$

### 依次类推:

$$C_8 = G_2^* + P_2^* G_1^* + P_2^* P_1^* C_0$$

$$C_{12} = G_3^* + P_3^* G_2^* + P_3^* P_2^* G_1^* + P_3^* P_2^* P_1^* C_0$$

$$C_{16} = G_4^* + P_4^* G_3^* + P_4^* P_3^* G_2^* + P_4^* P_3^* P_2^* G_1^* + P_4^* P_3^* P_2^* P_1^* C_0$$

## (2)多级先行进位方式



若不考虑G、P的形成时 间,C。经过2ty产生第1 小组的C<sub>1</sub>、C<sub>2</sub>、C<sub>3</sub>及所有 组进位产生函数G<sub>i</sub>\*和组 进位传递函数P:\*; 再经过 2ty,产生C<sub>4</sub>、C<sub>8</sub>、C<sub>12</sub>、 C<sub>16</sub>; 最后经过2ty后, 才 能产生第2、3、4小组内 的 $C_5 \sim C_7$ 、 $C_9 \sim C_{11}$ 、 $C_{13} \sim C_{15}$ 。



#### 定点数运算



计算机内定点数一般用<mark>补码表示;思考为什么?</mark> 补码加减运算规则如下:

- (1)参加运算的两个操作数均用补码表示;
- (2)符号位作为数的一部分参加运算;
- (3)若做加法,则两数直接相加;若做减法,则将被减数与减数的机器负数相加;
- (4)运算结果用补码表示。

#### 结论公式:

$$[X + Y]_{\dot{k}h} = [X]_{\dot{k}h} + [Y]_{\dot{k}h}$$
(1)  
$$[X - Y]_{\dot{k}h} = [X]_{\dot{k}h} + [-Y]_{\dot{k}h}$$
(2)

其中, [-Y]<sub>补</sub> 称为=[Y]<sub>补</sub>的机器负数, [-Y]<sub>补</sub>=[[Y]<sub>补</sub>]<sub>变补</sub>

[Y]<sub>补</sub>连同符号一起变反、末尾+1。



例1: A=0.1011, B=-0.1110,

求: A+B

 $: [A]_{k} = 0.1011, [B]_{k} = 1.0010$ 

0.1011

+ 1.0010

1.1101

 $\therefore [A+B]_{\lambda k} = 1.1101, A+B=-0.0011$ 

例2: A=0.1011, B=-0.0010,

求: A-B

 $::[A]_{i}=0.1011, [B]_{i}=1.1110,$ 

 $[-B]_{\lambda} = 0.0010$ 

0.1011

+ 0.0010

0.1101

 $\therefore$ [A-B]<sub> $\frac{1}{2}$ h</sub>=0.1101, A-B=0.1101

两数补码加减计算结果一定可用吗?

#### 补码计算溢出判断



#### 思考: 什么时候会溢出?

#### 溢出检测方法

设:被操作数为: [X]<sub>补</sub>=X<sub>s</sub>,X<sub>1</sub>X<sub>2</sub>...X<sub>n</sub> 持

其和 (差) 为:  $[\ddot{S}]_{i_1} = S_s, S_1 S_2 ... S_n$  产生的进位为 $\ddot{C}_s, C_1 C_2 ... C_n$ 

操作数为:[Y]<sub>补</sub>=Y<sub>s</sub>,Y<sub>1</sub>Y<sub>2</sub>...Y<sub>n</sub> 产生的进位为C<sub>s</sub>,C<sub>1</sub>C<sub>2</sub>...C<sub>n</sub>

(1)硬件检测方法一:采用一个符号位

(2)硬件检测方法二:采用进位位

溢出=
$$C_s\overline{C_1}+\overline{C_s}C_1=C_s\oplus C_1$$

(3)硬件检测方法三:采用变形补码(双符号位)

#### 双符号位溢出判断



在双符号位的情况下,把左边的符号位S<sub>s1</sub>叫做真符,因为它代表了该数真正的符号,两个符号位都作为数的一部分参加运算。 这种编码又称为变形补码。变形补码存储时仍然保存单符号位, 运算时扩充成双符号位。

双符号位的含义如下:

S<sub>s1</sub>S<sub>s2</sub>=00 结果为正数,无溢出 S<sub>s1</sub>S<sub>s2</sub>=01 结果正溢

S<sub>s1</sub>S<sub>s2</sub>=10 结果负溢

 $S_{s1}S_{s2}=11$  结果为负数,无溢出

变形补码的本质是扩大了模,对于定点小数来说,模为4,对于 字长为n+2位的整数来说,模为2n+2

### 定点乘法运算



原码一位乘法类似于手工计算(自学)。 乘积  $P = |X| \times |Y|$  符号 $P_s = X_s \oplus Y_s$ 

补码一位乘法: Booth乘法

乘法运算需要3个寄存器:

A寄存器: 部分积与最后乘积的高位部分, 初值为0。

B寄存器:被乘数X。

C寄存器: 乘数Y, 运算后C寄存器中不再需要保留乘

数,改为存放乘积的低位部分。

### Booth乘法



#### Booth乘法规则如下:

- ① 参加运算的数用补码表示;
- ② 符号位参加运算;
- ③ 乘数最低位后面增加一位附加位Y<sub>n+1</sub>, 其初值为0;
- ④ 由于每求一次部分积要右移一位,所以乘数的最低两位 $Y_n$ 、  $Y_{n+1}$ 的值决定了每次应执行的操作;

### 判断位 $Y_n Y_{n+1}$ 操作

- 00 原部分积右移一位
- 0 1 原部分积加[X]<sub>\*</sub>后右移一位
- 10 原部分积加[-X]<sub>补</sub>后右移一位
- 11 原部分积右移一位

- ⑤ 移位按补码右移规则进行;
- ⑥ 共需做n+1次累加,n次 移位,第n+1次不移位。

例: 已知X=-0.1101, Y=0.1011; 求X×Y。

$$[X]_{ab}=1.0011 \rightarrow B, [Y]_{ab}=0.1011 \rightarrow C, 0 \rightarrow A$$

$$[-X]_{\frac{1}{2}}=0.1101$$

|                                                       | A            | C <b>附加位</b>                                                    | 说明         |
|-------------------------------------------------------|--------------|-----------------------------------------------------------------|------------|
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$  | 0. 1 0 1 1 0 | $C_4C_5=10, +[-X]_{\frac{1}{4}}$                                | <b>{</b> } |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$  | 1 0 1 0 1 1  | 部分积右移一位<br>C <sub>4</sub> C <sub>5</sub> =11,+0                 |            |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 0 1 0 1 0 1  | 部分积右移一位<br>C <sub>4</sub> C <sub>5</sub> =01,+[X] <sub>补</sub>  |            |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 0 0 1 0 1 0  | 部分积右移一位<br>C <sub>4</sub> C <sub>5</sub> =10,+[-X] <sub>5</sub> |            |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$  | 0 0 0 1 0 1  | 部分积右移一位<br>C <sub>4</sub> C <sub>5</sub> =01,+[X] <sub>补</sub>  | •          |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$  | 001          | •                                                               |            |

 $(X \times Y)_{*} = 1.01110001$ 

 $X \times Y = -0.10001111$ 

思考: 还可以更快吗?

自学: 补码两位乘法

### 定点除法运算



- 1.原码比较法、恢复余数法和不恢复余数法(原码加减交替法)(自学)
- 2.补码加减交替除法规则,求新余数公式:  $[r_{i+1}]_{i+1} = 2[r_i]_{i+1} + (1-2Q_i) \times [Y]_{i+1}$

| [X] <sub>补</sub> 与[Y] <sub>补</sub> | 第一次操作                                | [r <sub>i</sub> ] <sub>补</sub> 与[Y] <sub>补</sub> | 上商 | 求新余数[r <sub>i+1</sub> ] <sub>补</sub> 的操作                                                                                                                |
|------------------------------------|--------------------------------------|--------------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 同号                                 | Гу] _[у]                             | ①同号<br>(够减)                                      | 1  | $\left[\mathbf{r}_{\mathbf{i}+1} ight]_{ eq h} = 2\left[\mathbf{r}_{\mathbf{i}} ight]_{ eq h} - \left[\mathbf{Y} ight]_{ eq h}$                         |
| L1 7                               | $[X]_{\frac{1}{4}}$                  | (<br>9級)<br>②异号<br>(不够减)                         | 0  | $[r_{i+1}]_{i}=2[r_{i}]_{i}+[Y]_{i}$                                                                                                                    |
| <br>异号                             | [X] <sub>¾h</sub> +[Y] <sub>¾h</sub> | ①同号<br>(不够减)                                     | 1  | $\left[\mathbf{r}_{\mathbf{i}+1}\right]_{ ext{lpha} ext{\begin{subarray}{c} \mathbf{r}_{\mathbf{i}} \end{bmatrix}} ext{\ext{\ext{\ext{\ext{\ext{\ext{\$ |
|                                    | ¼r ¾r                                | ②异号<br>(够减)                                      | 0  | $[r_{i+1}]_{\not=k}=2[r_i]_{\not=k}+[Y]_{\not=k}$                                                                                                       |

已知: X=0.1000, Y=-0.1010; 求X÷Y

 $[X]_{\frac{1}{2}h} = 0.1000 \rightarrow A, [Y]_{\frac{1}{2}h} = 1.0110 \rightarrow B, 0 \rightarrow C, [-Y]_{\frac{1}{2}h} = 0.1010$ 

| $+[Y]_{*}$ 0 0.1 0 0 0 + [Y]                         | 0.0000    | [X] <sub>补</sub> 、[Y] <sub>补</sub> 异号,+[Y] <sub>补</sub>                                                                   |
|------------------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------|
| 1 1.1 1 1 0                                          | 0.0001    | [X] <sub>补</sub> 、[Y] <sub>补</sub> 异号,+[Y] <sub>补</sub><br>[r <sub>i</sub> ] <sub>补</sub> 、[Y] <sub>补</sub> 同号,商1<br>左移一位 |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$ |           | 上 <b>夕</b> 一位<br>+[-Y] <sub>补</sub>                                                                                       |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 0.0010    | [r <sub>i</sub> ] <sub>补</sub> 、[Y] <sub>补</sub> 异号,商0                                                                    |
| $+[Y]_{*}$ 1 1. 0 1 1 0                              |           | $+[Y]_{{\not=}}$                                                                                                          |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 0.0100    | [r <sub>i</sub> ] <sub>补</sub> 、[Y] <sub>补</sub> 异号,商0                                                                    |
| $+[Y]_{*}$ 1 1.0 1 1 0                               |           | $+\begin{bmatrix} Y \end{bmatrix}_{\nearrow \downarrow}$                                                                  |
| 1 1.1 0 1 0     1 1.0 1 0 0                          | 0.1 0 0 1 | [r <sub>i</sub> ] <sub>补</sub> 、[Y] <sub>补</sub> 同号,商1                                                                    |
| $+[-Y]_{*}$ 0 0.1 0 1 0                              |           | $+\begin{bmatrix} -Y \end{bmatrix}_{\frac{1}{2}}$                                                                         |
| 1 1.1 1 1 0                                          | 1.0 0 1 1 | 末位恒置1                                                                                                                     |



#### 除法运算需要3个寄存器:

A寄存器:存放被除数X,最后A寄存器中剩下的是扩大了若干倍的余数。运算过程中A寄存器的内容将不断地发生变化。

B寄存器: 存放除数Y。

C寄存器: 存放商Q, 它的初值为0。

#### 规格化浮点运算



#### 浮点加减运算

#### 设两个非0的规格化浮点数分别为

$$\mathbf{A} = \mathbf{M_A} \times 2^{\mathbf{E_A}}$$

$$\mathbf{B} = \mathbf{M_B} \times 2^{\mathbf{E_B}}$$

$$\mathbf{A} \pm \mathbf{B} = (\mathbf{M_A}, \mathbf{E_A}) \pm (\mathbf{M_B}, \mathbf{E_B}) = \frac{M_A \pm M_B \times 2^{-(E_A - E_B)}}{(M_A \times 2^{-(E_B - E_A)} \pm M_B, E_B)} \times \frac{E_A > E_B}{E_A < E_B}$$

- (1)对阶: 规则是: 小阶向大阶看齐, 每右移一位, 阶码加1。
- (2)尾数加/减  $M_A \pm M_B \rightarrow M_C$
- (3)尾数结果规格化,设尾数用双符号位补码表示,经过加/减运算之后,可能出现以下六种情况:

#### 浮点加减规格化



① 00.1 x x ... x

(2) 11.0 x x ... x

(3) 00.0 x x ... x

(4) 11.1 x x ... x

(5) **01.**x x x ... x

(6) 10.x x x ... x

第①、②种情况,已是规格化数。

第③、④种情况需要使尾数左移以实现规格化,这个过程称为左规。尾数每左移一位,阶码相应减1,直至成为规格化数为止。(左规可能需进行多次)

第⑤、⑥种情况在定点加减运算中称为溢出;但在浮点加减运算中,只表明此时尾数的绝对值大于1,而并非真正的溢出。这种情况应将尾数右移以实现规格化。这个过程称为右规。尾数每右移一位,阶码相应加1。 (右规最多进行一次)

### 浮点数计算的溢出判断



当尾数之和 (差) 出现10.x x x ... x或01.x x x ... x时, 并不表示 溢出,只有将此数右规后,再根据阶码来判断浮点运算结果是否 溢出。

浮点数的溢出情况由阶码的符号决定,若阶码也用双符号位 补码表示,

[E<sub>C</sub>]<sub>补</sub>=10, x x x ... x, 表示下溢。浮点数值趋于零, 机器不 做溢出处理, 而是按机器零处理。



### 设两个非0的规格化浮点数分别为

$$A=M_A\times 2^{E_A}$$

$$B=M_B\times 2^{E_B}$$

### 则浮点乘法和除法为

$$A \times B = (M_A \times M_B) \times 2^{(E_A + E_B)}$$

$$A \div B = (M_A \div M_B) \times 2^{(E_A - E_B)}$$



- 1.乘法步骤
- (1)阶码相加

两个浮点数的阶码相加,当阶码用移码表示的时候,应 注意要减去一个偏置值2<sup>n</sup>。

因为
$$[E_A]_{8}=2^n+E_A$$
,  $[E_B]_{8}=2^n+E_B$   $[E_A+E_B]_{8}=2^n+(E_A+E_B)$  而 $[E_A]_{8}+[E_B]_{8}=2^n+E_A+2^n+E_B$ 

显然,此时阶码和中多余了一个偏置值2<sup>n</sup>,应将它减去。另外,阶码相加后有可能产生溢出,此时应另作处理。



(2)尾数相乘

与定点小数乘法算法相同。

(3)尾数结果规格化

因为 $1/2 < |\mathbf{M}_{A}| < 1$ ,  $1/2 < |\mathbf{M}_{B}| < 1$ , 所以 $1/4 < |\mathbf{M}_{A} \times \mathbf{M}_{B}| < 1$ .

当 $1/2 < |M_A \times M_B| < 1$ 时,乘积已是规格化数,不须再进行规格化操作;当 $1/4 < |M_A \times M_B| < 1/2$ 时,则需要左规一次。



- 2.除法步骤
- (1)尾数调整

首先须要检测 $|M_A| < |M_B|$ 。如果不小于,则 $M_A$ 右移一位, $E_A+1 \to E_A$ ,称为尾数调整。因为A、B都是规格化数,所以最多调整一次。

(2)阶码相减

两浮点数的阶码相减,当阶码用移码表示时,应注意要加上一个偏置值2<sup>n</sup>。

(3)尾数相除

与定点小数除法算法相同。

### 逻辑运算



逻辑运算比算术运算要简单得多,这是因为逻辑运算是按位进行的,位与位之间没有进位/借位的关系。

### 1.逻辑非

逻辑非又称求反操作,它对某个寄存器或主存单元中各位代码按位取反。

### 2.逻辑乘

逻辑乘就是将两个寄存器或主存单元中的每一相应位的代码进行"与"操作。

### 逻辑运算



### 3.逻辑加

逻辑加就是将两个寄存器或主存单元中的每一相应位的代码进行"或"操作。

### 4.按位异或

按位异或是计算机中一个特定的逻辑操作,它对寄存器或主存单元中各位的代码求模2和,又称模2加或半加,也叫异或。



运算器是在控制器的控制下实现其功能的,运算器不仅可以完成数据信息的算逻运算,还可以作为数据信息的传送通路。

1.运算器的基本组成

基本的运算器包含以下几个部分: 实现基本算术、逻辑运算功能的ALU, 提供操作数与暂存结果的寄存器组, 有关的判别逻辑和控制电路等。



### (1)带多路选择器的运算器





#### (2)带输入锁存器的运算器





- 2.运算器的内部总线结构
- (1)单总线结构运算器 运算器实现一次双操作数的运算需要分成三步。
- (2)双总线结构运算器 运算器实现一次双操作数的运算需要两步。





### (3)三总线结构运算器 实现一次双操作数的运算仅需要一步。



### ALU举例



#### 1.ALU电路

ALU即算术逻辑单元,它是既能完成算术运算又能完成逻辑运算的部件。前面已经讨论过,无论是加、减、乘、除运算,最终都能归结为加法运算。因此,ALU的核心首先应当是一个并行加法器,同时也能执行像"与"、"或"、"非"、"异或"这样的逻辑运算。由于ALU能完成多种功能,所以ALU又称多功能函数发生器。



#### 2.4位ALU芯片

74181是四位算术逻辑运算部件 (ALU) , 又称多功能函数发生器, 能执行16种算术运算和16种逻辑运算。

A0、B0~A3、B3: 操作数输入端;

F0~F3: 输出端;

Cn': 进位输入端;

C<sub>n+4</sub>':进位输出端;

G\*: 组进位产生函数输出端;

P\*: 组进位传递函数输出端;



M: 工作方式,M=0为算术操作,M=1为逻辑操作;

 $S_0 \sim S_3$ : 功能选择线。

74181的4位作为一个小组,组间既可以采用串行进位,也可以采用并行进位。

当采用组间串行进位时,只要把前片的 $C_{n+4}$ 与下一片的





| 工作选择           | 负逻辑                    |                         |                        | 正逻辑                    |                         |                        |  |
|----------------|------------------------|-------------------------|------------------------|------------------------|-------------------------|------------------------|--|
| $S_3S_2S_1S_0$ | 逻辑运算                   | 算术运算(M=0)               | 算术运算 (M=0)             | 逻辑运算                   | 算术运算(M=0)               | 算术运算(M=0)              |  |
|                | (M=1)                  | C <sub>m</sub> =0 (无进位) | C <sub>n</sub> =1 有进位) | (M=1)                  | C <sub>n</sub> =1 (无进位) | C <sub>n</sub> =0 有进位) |  |
| 0000           | F=Ā                    | F=A 減 1                 | F=A                    | $F = \overline{A}$     | F=A                     | F=A加1                  |  |
| 0001           | F= <del>AB</del>       | F=AB减1                  | F=AB                   | $F = \overline{A + B}$ | F=A+B                   | F=(A+B)加 1             |  |
| 0010           | F= \overline{A} + B    | F=AB减1                  | F=A B                  | F= AB                  | F=A+ B                  | F=(A+B̄)加 1            |  |
| 0011           | F=1                    | F=减 1                   | F=0                    | F=0                    | F=减 1                   | F=0                    |  |
| 0100           | $F = \overline{A + B}$ | F=A加(A+ B)              | F=A加(A+B)加1            | F= <del>AB</del>       | F=A加 A B                | F=A加AB加1               |  |
| 0101           | F=B                    | F=AB加(A+Ē)              | F=AB加(A+Ē)加1           | F=B                    | F=(A+B)加 A B            | F=(A+B)加 A B 加 1       |  |
| 0110           | F= <del>A⊕B</del>      | F=A減B減1                 | F=A減B                  | F=A⊕B                  | F=A減B減1                 | F=A減B                  |  |
| 0111           | F=A+ B                 | F=A+ B                  | F=(A+B)加1              | F=A B                  | F=AB减1                  | F=AB                   |  |
| 1000           | F=ĀB                   | F=A加(A+B)               | F=A加(A+B)加1            | F=Ā+B                  | F=A加 AB                 | F=A加 AB加1              |  |
| 1001           | F= A ⊕ B               | F=A加 B                  | F=A加B加1                | F= <del>A⊕B</del>      | F=A加 B                  | F=A加B加1                |  |
| 1010           | F=B                    | F=A B 加(A+B)            | F=A B 加(A+B)加 1        | F=B                    | F=(A+B)加 AB             | F=(A+B)加 AB 加 1        |  |
| 1011           | F=A+B                  | F=A+B                   | F=(A+B)加 1             | F=AB                   | F=AB 减 1                | F=AB                   |  |
| 1100           | F=0                    | F=A加 A*                 | F=A加A加1                | F=1                    | F=A加 A*                 | F=A加A加1                |  |
| 1101           | F=A B                  | F=AB加A                  | F=AB加A加1               | F=A+ B                 | F=(A+B)加 A              | F=(A+B)加 A 加 1         |  |
| 1110           | F=AB                   | F=AB加A                  | F=AB加A加1               | F=A+B                  | F=(A+B̄)加 A             | F=(A+B̄)加 A 加 1        |  |
| 1111           | F=A                    | F=A                     | F=A加1                  | F=A                    | F=A減1                   | F=A                    |  |



#### 3. ALU的应用

当采用组间并行进位时,需要增加一片先行进位部件 (74182)。





74182可以产生三个进位信号 $C_{n+x}$ 、 $C_{n+y}$ 、 $C_{n+z}$ ,并且还产生大组进位产生函数 $G^{**}$ 和大组进位传递函数 $P^{**}$ ,可供组成位数更长的多级先行进位ALU时用。

$$C_{16} = G_4^* + P_4^* G_3^* + P_4^* P_3^* G_2^* + P_4^* P_3^* P_2^* G_1^* + P_4^* P_3^* P_2^* P_1^* C_0$$

$$=G_1^{**}+P_1^{**}C_0$$

大组进位 产生函数**G**<sub>1</sub>\*\*

大组进位 传递函数**P**<sub>1</sub>\*\*\*

74181和74182的结合可组成各种位数的ALU部件。

8片74181和2片74182构成的32位两级行波ALU。各片74181输出的组进位产生函数和组进位传递函数作为74182的输入,而74182输出的进位信号  $C_{n+x}$ 、 $C_{n+y}$ 、 $C_{n+x}$ 作为74181的输入,74182输出的大组进位产生函数和大组进位传递函数可作为更高一级74182的输入。

#### 实验一:设计并实现一个32位ALU



- 要求: 1、支持至少8种运算, 自行选择, 实验报告中说明;
  - 2、输出5个标志符号: SF(符号位), CF (进位标志), ZF (零
- 标志), (溢出标志)和PF(奇偶标志);
  - 3、支持左右移位操作;
  - 4、可支持至少两种舍入操作。
- 5、(可选)对ALU进行改进,写出改进目标,以及改进的量化对比结果。(例如:时间上的缩短,逻辑单元减少等)

实验环境vivado2019.2 语言: Verilog HDL。

乐学提交: 1、实验报告, 姓名-学号-实验一.pdf或doc/docx格式

2、带源代码的工程文件。姓名-学号-实验一.zip

### 关于运算器的重要认识



- · 重要认识1: 计算机中所有算术运算都基于加法器实现, n位 计算时是一种模2<sup>n</sup>运算系统!
- · 重要认识2:无符号整数和带符号整数的加、减运算电路完全一样,这个运算电路称为整数加减运算部件,基于带标志加法器实现。
- · 重要认识3:加法器不判定对错,总是取低n位作为结果,并 生成标志信息。

#### 示例: n位整数加/减运算部件



• 利用带标志加法器,可构造整数加/减运算器,进行以下运算:

无符号整数加、无符号整数减

带符号整数加、带符号整数减

在整数加/减运算部件基础上,加上寄存器、移位器以及控制逻辑,就可实现ALU、乘/除运算以及浮点运算电路

当Sub为1时,做减法sub 当Sub为0时,做加法



整数加/减运算部件

#### 标志位的生成示例





带标志加法器的逻辑电路

溢出标志OF: OF=C<sub>n</sub>⊕C<sub>n-1</sub>

符号标志SF: SF=F<sub>n-1</sub>

零标志ZF=1当且仅当F=0;

进位/借位标志CF:

**CF=Cout⊕Cin** 

条件标志(Flag)在运算电路中产生,被记录到专门的寄存器中

### 算术逻辑部件 (ALU): 多功能函数发生器



- 进行基本算术运算与逻辑运算
  - 无符号整数加、减
  - 带符号整数加、减
  - 与、或、非、异或等逻辑运算
- 核心电路是整数加/减运算部件
- 输出除和/差等,还有标志信息
- · 有一个操作控制端 (ALUop) ,用来决定ALU所立处理功能。ALUop的位数k决定了操作的种类,仍位数k为3时,ALU最多只有23=8种操作。



|        | ALUop | Result | ALUop | Result | ALUop | Result | ALUop | Result |
|--------|-------|--------|-------|--------|-------|--------|-------|--------|
|        | 000   | A加B    | 010   | A与B    | 100   | A取反    | 110   | Α      |
| P<br>Z | 001   | A减B    | 011   | A或B    | 101   | A⊕B    | 111   | 未用     |



# 感谢聆听